# Проектирование в Quartus II

Размещение и настройка выводов



## I/O Planning

 Ввод настроек размещения выводов и связанных настроек

#### Анализ

- Процесс компиляции
- Проверка размещения во время ввода (Live I/O checking)
- Проверка помех при одновременных переключениях (Simultaneous Switching Noise - SSN)



## Ввод настроек

Для ввода настроек, связанных с размещением выводов, обычно используются следующие средства:

- Pin Planner
- Импорт из таблиц в формате CSV
- Скрипты TCL
- Редактирование файла QSF в текстовом редакторе

Note: Other methods/tools are available in the Quartus II software to make I/O assignments. The above are the most common or recommended.



#### Pin Planner

- Интерактивный графический редактор для настройки размещения и параметров выводов
  - Поддержка размещения drag & drop
  - Установка стандарта и параметров элемента ввода-вывода
  - Резервирование выводов
- Три основных панели
  - Package View
  - Список выводов (All Pins)
  - Список групп (Groups)

Меню
Assignments → Pin Planner
или папка
"Assign Constraints"
в панели Tasks



#### Окно Pin Planner





#### Окно Pin Planner

#### Package View

- Графическое представление корпуса
- Ввод настроек размещения выводов
- Определение взаимного расположения выводов
- Определение расположения служебных выводов (питание и конфигурация)

#### Список All Pins

- Вывод входных/выходных сигналов в соответствии с фильтром
- Позволяет редактировать размещение и другие свойства вывода

#### Список Groups

- Аналогичен списку All Pins, но отображает только группы и шины
- Используется для ввода настроек сразу на всю шину или группу
- Возможность создавать группы, определяемые пользователем

#### Панель задач

Запуск задач, например, раннее планирование выводов (Early Pin Planning) и просмотр изменений

#### Панель отчетов

Управление выводом результатов выполнения задач



## Размещение выводов в Pin Planner







## Размещение выводов в Pin Planner



## Другие возможности

- Различные режимы отображения
  - Стороны кристалла
  - Банки
  - Группы VREF
  - Диф. пары
  - Выводы DQ/DQS
- Переключение
  - меню View ⇒ Show
  - кнопки панели инструментов
  - Контекстное меню
- Вывод легенды с описанием обозначений
  - View → Pin Legend или кнопка





## Отображение выводов DQ/DQS

- View => Show => Show DQ/DQS Pins
- Вывод подсвеченных групп DQ/DQS в режимах х4, х8/х9, х16/х18 и х32/х36 для интерфейсов DDR



## Просмотр Pin Migration

- Устройства для миграции должны быть выбраны в диалоге Assignments => Device
- Диалог View => Pin Migration отражает разницу в функциях выводов
- Package View блокирует несовместимые настройки размещения







## Дополнительные возможности (1)

#### Pin Finder



- Выбор выводов по критериям, заданным пользователем
- Используется для поиска совместимых выводов
- Найденные выводы подсвечиваются в Package View





## Дополнительные возможности (2)

- Настройка столбцов
  - Выбор столбцов, выводимых в списке All Pins





## Панели Tasks и Report

- Используйте панель Tasks для выполнения типичных операций
- Папка Change View изменяет отображение (аналогично меню View)
- Папка Highlight Pins выполняет подсветку выводов в соответствии со сформированными отчетами





## Резервирование выводов

- В списке Pins щелкните по <<new node>> и введите имя
- В столбце Location укажите размещение
- В столбце Reserved выберите конфигурацию вывода



- Или вызовите контекстное меню на выводе в Package View и выберите Reserve → As...
  - Создается вывод с именем user\_reserve\_<pin\_number>



## Отображение настроек разводчика

- Отображает размещение выводов после разводки
- Размещение может быть сохранено как постоянное через меню Assignments => Back-Annotate...

View → Show → Show Fitter Placements или кнопка







## Другие методы ввода настроек: импорт/экспорт из CSV

- Используйте формат с разделением запятыми (.CSV) для ввода или редактирования настроек размещения выводов
- Удобно использовать для переноса настроек между проектами и ревизиями
- Имена столбцов в CSV должны соответствовать именам столбцов Pin Planner







## Другие методы ввода настроек: редактирование QSF и скрипты Tcl

- Ручное редактирование файла QSF
- Создание отдельного файла Tcl с настройками
  - Для записи настроек в QSF выполните скрипт Tcl через меню Tools => Tcl Scripts

Можно выполнить скрипт непосредственно в QSF

```
💚 Text Editor - C:/altera_trn/Intro/pipemult - pipemult_lc - [location_assignments.tcl] 🔻 🕒 🔀
🖐 Text Editor - C:/altera_trn/Intro/pipemult - pipemult - [pipemult.qsf]*
                                                                         File Edit View Project Processing Tools Window Help
                                                                                                                               Search altera.com
    Edit View Project Processing Tools Window
                                                           Search altera.co
                                                                                  set location assignment PIN A15 -to datab[6]
                                                                           23
  20
                                                                                  set location assignment PIN D17 -to datab[5]
                                                                                  set location assignment PIN J13 -to datab[4]
  21
         # Altera recommends that you do not modify this file. The
                                                                                     location assignment PIN M16 -to clk1
         # file is updated automatically by the Quartus II softwa
  22
                                                                           26
  23
         # and any changes you make may be lost or overwritten.
                                                                           27
                                                                                  set location assignment PIN J17 -to dataa[6]
  24
                                                                                     location assignment PIN C15 -to dataa[5]
                                                                           28
  25
         source "location assignments.tcl"
                                                                           29
  26
                                                                                  set location assignment PIN H16 -to dataa[3]
         set global assignment -name DEVICE EP3C5F256C6
                                                                           31
                                                                                     location assignment PIN B15 -to dataa[2]
  28
         set global assignment -name FAMILY "Cyclone III"
                                                                           32
                                                                                     location assignment PIN B13 -to dataa[1]
  29
         set global assignment -name TOP LEVEL ENTITY pipemult
                                                                           33
                                                                                      location assignment PIN G11 -to q[15]
         set global assignment -name ORIGINAL QUARTUS VERSION 6
                                                                           34
                                                                                      instance assignment -name IO STANDARD "2.5 V" -to q[15]
  31
         set global assignment -name PROJECT CREATION TIME DATE
                                                                           35
                                                                                      location assignment PIN E15 -to q[14]
  32
         set global assignment -name LAST QUARTUS VERSION 12.1
                                                                           36
  33
         set global assignment -name DEVICE FILTER PACKAGE FBGA
  34
         set global assignment -name DEVICE FILTER PIN COUNT
                                                                                                                                     0%
                                                                                                                                           00:00:00
                                                                 0%
                                                                        00:00:00
```

## Проверка настроек размещения

- I/O Assignment Analysis
  - Проверяет корректность настроек без полной компиляции
- Необходимые требования к проекту
  - Выводы должны быть объявлены
    - В исходных файлах проектах
    - Как зарезервированные
  - Настройки на выводы
    - Стандарт ввода-вывода
    - Current strength
    - Размещение (вывод, банк, сторона)
    - Диод РСІ
    - Частота переключения

Запуск из меню Processing → Start → Start I/O Assignment Analysis

или

Запуск из панели инструментов Pin Planner





## Проверка правил

#### Если внутренняя логика не реализована

- Проверяет корректность настройки взаимного расположения выводов и распределение по банкам
- Например, в одном банке должны быть выводы с одним напряжением питания

#### ■ Если выводы связаны с логикой

- Дополнительно проверяет корректность связи с внутренними ресурсами
- Например, сигнал на PLL должен подаваться с входа тактовых импульсов
- При наличии внутренней логики требуется провести синтез до запуска I/O Assignment Analysis



## Отчет I/O Assignment Analysis



## Проверка при вводе (Live I/O Checking)

- Возможна частичная проверка корректности при вводе настроек в Pin Planner
- Ошибки выводятся в окне сообщений

Для полной проверки все равно нужно запустить

I/O Assignment Analysis





## **Swappable Pins**

- Поиск совместимых выводов для обмена назначениями сигналов
- Сопрягается с Live I/O Check
  - Live I/O Check должна быть включена



Вызов из меню View → Find Swappable Pins или панель инструментов





## Проверка корректности настроек

- Для готового проекта
  - Запуск полной компиляции
  - Для ускорения проверки в меню Assignments => Settings => Compilation Process Settings включите опцию Run I/O Assignment Analysis before compilation
- Проект не завершен (не может быть откомпилирован)
  - Запустите Processing => Start => Run I/O Assignment Analysis
- Проект не завершен (нет файлов проекта)
  - Онлайн-тренинг <u>I/O System Design</u> (http://www.altera.com/education/training/courses/ODSW1107)
  - Онлайн-тренинг <u>Fast & Easy I/O System Design with BluePrint</u>
     для Arria 10/Stratix 10
  - (http://wl.altera.com/education/training/courses/OBLUEINTRO)



#### Резюме

- Настройки выводов могут осуществлять разными способами, с использованием графического интерфейса и текстовых файлов
- Средство Pin Planner предоставляет простой графический интерфейс для ввода настроек выводов и управления ими
- Режим компиляции I/O Assignment Analysis позволяет проверить назначения выводов без полной компиляции
- Режим Live I/O checking осуществляет проверку корректности во время ввода настроек
- Проверка корректности настроек выводов может быть осуществлена на любой стадии разработки проекта



## Материалы по настройкам выводов

- Главы Quartus II Handbook (Volume 2)
  - Managing Device I/O Pins
  - Signal Integrity Analysis with Third-Party Tools
  - Mentor Graphics PCB Design Tools Support
  - Cadence PCB Design Tools Support
- Pin Connection Guidelines
- Device Pin-Outs
- Board Design Resource Center
  - https://www.altera.com/support/support-resources/supportcenters/board-design-guidelines.html



# Проектирование в Quartus II

Программирование и конфигурация



## Содержание

- Настройка параметров устройства
- Программатор Quartus II
- Преобразование файлов для программирования



## Настройка параметров устройства

- Осуществляется в диалоге Assignments => Device and Pin Options
- Определяет глобальные параметры устройства (параметры конфигурации, режим работы неиспользуемых выводов и т.д.)





## Программатор Quartus II

- Quartus II Programmer
- Используется для внутрисхемного программирования микросхем Altera







## Выбор программатора





## Основные файлы для программирования

#### SOF (SRAM Object File)

 Используется для конфигурации ПЛИС на основе статической памяти (семейства Stratix, Arria и Cyclone) из Quartus II через загрузочный кабель

#### .POF (Programming Object File)

 Используется для программирования энергонезависимых ПЛИС (MAX, MAXII, MAXV) и конфигурационных ПЗУ

#### JAM/.JBC

Текстовый файл, используемый процессорами и сторонним тестовым оборудованием для программирования и конфигурации устройств через JTAG

#### JIC (JTAG Indirect Configuration File)

 Используется для программирования конфигурационных ПЗУ для режимов AS (семейство EPCS) и AP (микросхемы StrataFlash компании Micron)



#### **JTAG Chain**





## Опции программирования



\*)Только для ПЗУ и MAX/MAXII/MAXV. ПЛИС на основе статической памяти не поддерживают считывание прошивки



## Запуск программирования





## Создание файлов .jam/.jbc

Файлы в форматах JAM и JBC предназначены для конфигурации и программирования устройств через JTAG сторонним тестовым оборудованием, а также процессорами, в которых программно реализован JTAG Player (проигрывание файлов по JTAG)



## Программирование конфигурационных ПЗУ





## Создание .jic файла



- 1. Откройте диалог File -> Convert Programming Files
- 2. Выберите тип файла.jic в списке Programming file type
- 3. В списке Input Files выберите Flash Loader в таблице, нажмите кнопку "Add Device" и выберите ПЛИС
- 4. Убедитесь, что в поле SOF Data указан правильный файл конфигурации. Для смены нажмите кнопку "Add Sof Data".
- 5. Нажмите кнопку "Generate"



